import java.util.ArrayList;
import java.util.List;

public class Solution {
    /*
    给定一个只包括 '('，')'，'{'，'}'，'['，']' 的字符串 s ，判断字符串是否有效。
    有效字符串需满足：
        左括号必须用相同类型的右括号闭合。
        左括号必须以正确的顺序闭合。
     */
    public static boolean isValid(String s) {
        List<Character> queue = new ArrayList<>();
        int cur = 0;

        for (int i = 0; i < s.length(); i++) {
            switch (s.charAt(i)) {
                case '(': {
                    queue.add(cur, '(');
                    cur++;
                }
                break;
                case ')': {
                    if (cur < 1) {
                        return false;
                    }
                    if (queue.get(cur - 1).equals('(')) {
                        queue.remove(cur - 1);
                        cur--;
                    } else {
                        return false;
                    }
                }
                break;
                case '[': {
                    queue.add(cur, '[');
                    cur++;
                }
                break;
                case ']': {
                    if (cur < 1) {
                        return false;
                    }
                    if (queue.get(cur - 1).equals('[')) {
                        queue.remove(cur - 1);
                        cur--;
                    } else {
                        return false;
                    }
                }
                break;
                case '{': {
                    queue.add(cur, '{');
                    cur++;
                }
                break;
                case '}': {
                    if (cur < 1) {
                        return false;
                    }
                    if (queue.get(cur - 1).equals('{')) {
                        queue.remove(cur - 1);
                        cur--;
                    } else {
                        return false;
                    }
                }
                break;
            }
        }

        return cur == 0;
    }

    public static void main(String[] args) {
        System.out.println(isValid("([)]"));
        System.out.println(isValid("()"));
        System.out.println(isValid("()[]{}"));
        System.out.println(isValid("([{}])"));
        System.out.println(isValid("(()[{}])"));
    }
}
